bitkeeper revision 1.1343 (42669573FPZbSiupGqFkPopp_NRfpA)
authorkaf24@firebug.cl.cam.ac.uk <kaf24@firebug.cl.cam.ac.uk>
Wed, 20 Apr 2005 17:46:27 +0000 (17:46 +0000)
committerkaf24@firebug.cl.cam.ac.uk <kaf24@firebug.cl.cam.ac.uk>
Wed, 20 Apr 2005 17:46:27 +0000 (17:46 +0000)
Make the fallback memset/memcpy/memmove have a concrete in-place
implementation, or we end up with a recursive dependency when building
for x86/64.
Signed-off-by: Keir Fraser <keir@xensource.com>
xen/arch/x86/string.c

index 5a7788ba118ba87a132b53992b7b2fea40ae1468..b45a9197d5a8782193524f5b5998f02fff69fd21 100644 (file)
@@ -9,19 +9,55 @@
 #include <xen/lib.h>
 
 #undef memmove
-void *memmove(void *dest, const void *src, size_t count)
+void *memmove(void *dest, const void *src, size_t n)
 {
-    return __memmove(dest, src, count);
+    int d0, d1, d2;
+    if ( dest < src )
+        return memcpy(dest, src, n);
+
+    __asm__ __volatile__ (
+        "   std         ; "
+        "   rep ; movsb ; "
+        "   cld           "
+        : "=&c" (d0), "=&S" (d1), "=&D" (d2)
+        : "0" (n), "1" (n-1+(const char *)src), "2" (n-1+(char *)dest)
+        : "memory");
+
+    return dest;
 }
 
 #undef memcpy
-void *memcpy(void *dest, const void *src, size_t count)
+void *memcpy(void *dest, const void *src, size_t n)
 {
-    return __memcpy(dest, src, count);
+    int d0, d1, d2;
+
+    __asm__ __volatile__ (
+        "   rep ; movsl      ; "
+        "   testb $2,%b4     ; "
+        "   je 1f            ; "
+        "   movsw            ; "
+        "1: testb $1,%b4     ; "
+        "   je 2f            ; "
+        "   movsb            ; "
+        "2:                    "
+        : "=&c" (d0), "=&D" (d1), "=&S" (d2)
+        : "0" (n/4), "q" (n), "1" (dest), "2" (src)
+        : "memory");
+
+    return dest;
 }
 
 #undef memset
-void *memset(void *s, int c, size_t count)
+void *memset(void *s, int c, size_t n)
 {
-    return __memset(s, c, count);
+    int d0, d1;
+
+    __asm__ __volatile__ (
+        "rep ; stosb"
+        : "=&c" (d0), "=&D" (d1)
+        : "a" (c), "1" (s), "0" (n)
+        : "memory");
+
+    return s;
 }